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SYSTEM AND METHOD FOR AUTOMATED LEAD 
GENERATION AND CLIENT CONTACT MANAGEMENT 
FOR A SALES AND MARKETING PLATFORM 

TECHNICAL FIELD 

5 The present invention relates to database and record management 

systems. 

BACKGROUND OF THE INVENTION 

Companies from many (Afferent businesses and industries are enga^g in 
new marketing strategies. To expand their customer base and establish new customers, 

10 companies must target potential customers with new or ongoing maAeting campaigns 
and contact development campaigns. Due to global expansion and industry 
convergence, markets are expanding and the mrniber of potential customers is increasing. 
Therefore, targeting potential customers must be done efficiently. 

Previous methods of identifying potential customers included identifying 

IS telephone numbers and corresponding customer names to perform mass calling 
campaigns. Mass calling campaigns are typically no longer effective because such 
campaigns require large volumes of resources, including telemarketers, 
telecommunication services, man hours, etc. Furthermore, mass calling campaigns often 
suffer from high failure rates. Moreover, since such campaigns focus on telephone 

20 numbers rather than individuals, the campaigns miss many potential customers. For 
example, one telephone number at a household could be associated with two or more 
individuals in that house, each of which may have separate needs, and each of which 
could be separately targeted. 

Customer data, including telephone numbers and customer names, are 

25 typically stored in a centralized and very large database. Prior calling campaigns would 
query the database for customers based on their telephone numbers {e.g.^ area code 
and/or three digit prefix). More recently, new marketing strategies and campaigns are 
formulated which query the database for certain criteria related to phone number records 
in the database. Since the database is centralized and very large, such queries consume 
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significant processing time and are therefore time-consuming. Furthermore, results firom 
such queries are often difiBcult to effectively employ m a given mass calling campaign. 
Moreover, marketing strategies and campaigns are limited to types and organizations of 
data within the database. 

5 SUMMARY OF THE INVENTION 

In a broad sense, the present invention embodies a computer implemented 
method for generating leads for nuirketing campaign fi-om client records stored in a data 
warehouse. The method includes the steps of: (a) creating a mart containing a subset of 
the client records stored m the data warehouse, (b) selecting a subset of the client 
10 records contained in the mart based on a first query, and (c) constructing lead records 
based on the selected subset of the client records and additional information stored in the 
data warehouse. 

In a broad sense, the present invention also embodies a system for 
generating lead records for a marketing campaign based on client records stored in a 

1 5 database. The system includes a user interface unit, a campaign management unit, a lead 
qualification filter unit, a lead management unit and a formatter unit. The user inter&ce 
unit accepts query commands firom a user. The campaign management unit receives the 
query conmfiands and creates a lead qualification filter. The lead qualification filter unit 
applies the lead qualification filter to the client data to extract selected client records. 

20 The lead management unit applies predetermined rules to the selected client records to 
produce a set of lead records. The formatter unit converts the lead records into 
formatted lead records for use in the marketing campaign. 

BRIEF DESCRIPTION OF THE DRAWINGS 

An exemplary embodiment of the present invention will be described in 
25 more detail relative to the following figures. 

Figure 1 is a block diagram showing an exemplary information system 
architecture suitable for practicmg the exemplary embodiment of the present invention. 

Figure 2 is a block diagram of a contact service infirastructure shown in 

Figure 1. 
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Figure 3 is a data flow diagram showing flow of data under an aspect of 
the information system architecture of Figure 1. 

Figure 4 is an exemplary data structure diagram of a lead record. 

Figure S is an exemplary data structure diagram of a lead distribution 

S record. 

Figure 6 is an exemplary flowchart showing basic steps and associated 
displayed screens of processes performed by campaign management and lead inventory 
management processes of the contact service infiastructure of Figure 2. 

Figure 7 is a firont view of a computer screen showing an exemplary user 

10 log in screen. 

Hgure 8 is a front view of a computer screen showing an exemplary main 

menu screen. 

Figure 9 is a front view of a computer screen showing an exemplary 
status query and determination screen. 
IS Figure 10 is a front view of a computer screen showing an exemplary lead 

marts initial query screen. 

Figure 1 1 is a fi^nt view of a computer screen showing an exemplary 
, initial query and display for a lead generation process. 

Rgure 12 is a front view of a computer screen showing an exemplary 
20 table selection screen. 

Figures 13 and 14 are front views of a computer screen showing 
exemplary lead mart management screens. 

Figures 15 and 16 are front views of a computer screen showing 
exemplary distribution query and display screens for lead generation processes. 
25 Figure 17 is a front view of a computer screen showing an exemplary 

save, submit or open lead generation queries screen. 

Figures 18, 19, 20 and 21 are front views of a computer screen showing 
exemplary results display screens based on lead generation queries. 

Figures 22, 23 and 24 are front views of a computer screen showing 
30 exemplary sales city, forms and media type screens. 
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Figure 25 is a front view of a computer sa-een showing an exemplary list 

code screen. 

Figure 26 is a front view of a computer screen showing an exemplary 
security screen. 

5 Figures 27A and 27B together show an exemplary table built for 

constructmg a lead mart. 

DETAILED DESCRIPTION OF THE INVENTION 

An information system architecture, and in particular, a system and 
method for providing enhanced marketing services based on data stored in a database, is 

10 described in detail herein. In the following description, numerous specific details are set 
forth such as data flow, data formatting, user interfaces, organization and coupling of 
processes, etc., in order to provide a thorough understanding of the present inventioa 
One skilled in the relevant art, however, will readily recognize that the present invention 
can be practiced without use of the specific details described herem, or with other 

15 specific data flow, data formatting, user interfaces, organization and coupling of 
processes, etc. Well-known structures, processes and steps are not shown or described 
in detail in order to avoid obscuring the present invention. 

1. Overview 

20 An ^emplary information system architecture and corresponding method 

under an embodiment of the present invention provides complete fimctionality for 
creating and implementing marketing campaigns, such as telemarketing and direct mail 
campaigns. The information system architecture permits users to formulate criteria fi^r 
targeting potential customers or clients (e.g., a query) based on a marketing strategy, 

25 identify and eTctract targeted clients from a centralized database or data warehouse, 
automatically generate leads, and track client contacts. 

The mformation system architecture, and many of its individual 
components, can be used for marketing efforts in virtually any type of business, such as a 
long distance telephone service provider. The embodiments of the present invention are 
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described herein with respect to a long distance telephone service provider, however, 
such description is for exemplary purposes only. 

The system includes a Contact Service Infrastructure (CONI). CONI is 
preferably a software-based system that runs on any type or types of computer(s) that 
5 meet minimum performance requirements. In its preferred embodiment, CONI provides 
client contact management, campaign management, and lead generation for the 
information system ardiitecture. CONI provides many of the strategic targeted 
marketing functions in the information system architecture by generating leads needed to 
implement a marketing campaign, and trackmg resulting activity based on those leads. 

10 CONI provides a graphical user interface (GUI) for users, where such 

users are typically business strategy units of a company (as discussed below). A user 
analyzes data from the data warehouse to formulate a new marketing strategy and 
employs CONI to implemrat that strategy. Employing the CONI GUI, the user specifies 
certain criteria to be used to target clients. CONI generates a query and extracts data 

1 S from the data warehouse which meets the criteria or query to form a localized data mart. 
Users can add additional criteria to further define or narrow extracted data to a final list 
extracted from the data mart. The final list is then formatted into leads, complete with 
. relevant data such as names, telephone numbers for telemarketing campaigns,- mailings 
addresses for direct mail campaigns, etc. The formatted leads are then distributed to 

20 various telemarketing and direct mail centers. 

CONI also manages a given campaign by receiving results from each 
client contact. CONI directs appropriate records to be updated and arranges follow-up 
for certain leads if requested. CONI also feeds results of each client contact back to the 
data warehouse to provide a feedback loop in the information system architecture. Such 

25 feedback loop ensures that data stored therein is current and accurate. 
2. System Architecture 

Referring to Figure 1, an exemplary information system architecture or 
strategic mariceting system (SaMS) infrastructure 100 is shown. The various 
components of the SaMS Infrastructure 100 interact cooperatively as shown in Figure 1 

30 to provide many targeted marketing functions, such as those described herein. The 
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SaMS infiastructure 100 performs at least three functions: client management, 
information management, and contact services. 

"Client management** includes the process of identifying, tracking and 
managing all of a conq)any's clients. "Clients** include both current customers and 
5 potential customers or leads, and therefore can consist of hundreds of millions of people 
for many companies. Client management involves descriptive behavioral data about 
cUents as individuals (rather than being based on, e.^., phone numbers). A primary 
component m the SaMS Infrastructure 100 for client management is a Client Acquisition 
and Retention Management Architecture (CARMA) 102. CARMA 102 is preferably a 
10 software system that provides a database and data processing for client management. 
An exemplary embodiment of CARMA 102 is described in detail in co-pending U.S. 
Patent Application entitled "System For Managing Client Sales and Mariceting Data,** 
which is filed concurrently here\^th and assigned to a common assignee of the present 
applicatioa 

15 "Information management** is the process of collecting, storing, and 

managing data that reflects entire client populations and trends. Information 
management provides decision support functions and tools that place raw data in context 

fQr.prP(Juct and niarketing strategies.- Information management deals .with descriptive . 

behavioral data about generalized client populations. A primary component for 

20 information management is a Dedsion Support System (DSS) 104. The DSS 104 
consists of a large-scale data warehouse, along with processes for collecting, storing, 
managing, distributing, and analyzing data. In general, a "data warehouse** is a 
consolidation of information for many departments or ''Business Strategy Units** within a 
company, as well as information extracted fi-om outside of the company. An exemplary 

25 embodiment of the DSS 104 is described below with respect to Figure 3. 

"Contact services** takes conclusions drawn from data warehouse queries 
and uses them to formulate marketing campaigns and generate leads. It also tracks and 
manages all contacts made with clients. COM 106 proNddes contact services for the 
SaMS hifrastructure 100. CONI 106 is preferably a sofhvare system that uses data 

30 extracted fi*om the data warehouse of the DSS 104, along with specific strategies 
formulated by a company's Business Strategy Units to generate leads. CONI 106 
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interfaces whh a Centralized Lead Repository (CLR) 108 to manage and track contacts 
with clients or leads, as described below. 

Liformation regarding such contacts made vnth clients ar« fed back to the 
client management function of the SaMS infrastructure 100. As a result, the client 

S manag^ent, information management, and contact services functions of the SaMS 
infrastructure 100 is a cyclic process: the information management function puts raw 
data into context to perform research, draw condusions and form strategies; the contact 
services function formalizes and implements mariceting strategies based on the researdi, 
condusions and strategies produced imder the information management fimction; and 
10 the client management function identifies and tracks individuals, collects descriptive and 
behavioral data, and provides such data back to the information management function. 

Various data providers 1 10 provide data to both CARMA 102 and DSS 
104. The data providers 110 inchide any source of data input to the SaMS 
Infrastructure 100 to provide information on cli^ts. The data providers 110 consist of 
1 S both internal data sources 1 12 and external data sources 1 14. Examples of internal data 
sources 1 12 include data feeds fi-om billing systems, customer order mtry systems, order 
provisioning systems, customer databases, marketing databases, customer service 
systems,.. accounts. receivable. ^stems, andmany others. They may also include input 
from other components of the SaMS infrastructure 100, such as the CLR 108. 

0 Examples of external data sources 114 include files of telephone 

directories, U.S. Post QfiSce directories, credit company reports, and many third party 
data products that provide spedfic data on people. These third party data products may 
include information such as products people buy, where people move to and from, 
services people utilize, and results from telephone surveys on people's interests and 

5 needs. External data sources 1 14 may also an wlines' frequent flier programs, auto club 
memberships, health dub memberships, travel clubs, and magazine subscriptions. These 
data are used to aid in tracking clients via clients* memberships and participation in other 
businesses. 

CARMA 102 collects data about specific clients from the data providers 
0 1 10, and uses the data to update client profiles. CARMA 102 then feeds any changes in 
client data to the DSS 104, but in a generalized form. That is, CARMA 102 does not 
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srad to the DSS 104 spedfic clients' names and addresses, but rather, sends information 
that reflects generic clients* profiles. CARMA 102 sends a unique client identifier with 
dimt profile changes, so that when leads are generated from data in the DSS 104, they 
can be matched to a specific name, address, and telephone number. In general, clients 
5 are typically identified under the SaMS infi-astructure 100 based on their client 
identifiers, \^ch are unique numeric or alphanum^c codes associated with each dient. 
Client identifiers are maintained in CARMA 102 and the DSS 104. 

The DSS 104 also collects data firom the data providers 110. The DSS 
104 typically collects data imrelated to specific clients, but rather groups of dients. Such 

10 data may include the number of people who moved firom one state to another, the 
number of people who purchased both a car and home stereo in the same year, or the 
number of women who own a business and are members of a political party. The 
pos^bilities for data collection by the DSS 104 are numerous, and vary according to the 
business needs of the user of the SaMS infirastructure 100. The DSS 104 also collects 

1 S data firom CARMA 102, and other sources, as described below. 

The DSS 104 allows Business Strategy Units (BSU) 116 to access data 
stored in its data warehouse. A BSU 116 can be a subset of a company responsible for 

. . . . J^tmulating bumess,,marketit^ For example, oncBSU 116 caiU)e. . -..^ 

respon^ble for international clirats, \dule another BSU 116 can be responsible for 

20 domestic cUents. Altemativdy, the BSU 116 can be the entire company employing the 
SaMS infirastructure 100. 

Users or BSUs 116 access the data stored in the DSS 104 for various 
fiinctions, including data survey, data mining, data drilling, predictive modeling, general 
queries and results delivery. The data survey fiinction helps the BSU 1 16 to identify 

25 potentially valuable groups of data. The data survey fiinction helps the BSU 116 find 
unanticipated patterns to guide marketing decisions. For example, a survey of a data 
mart (described below) may discover that 80% of a population in the northeast and with 
incomes of greater than $50,000 use cellular servdce. The BSU 116 can thereafter 
determine why income and geographic characteristics lead to celhilar usage. 

30 The data surve^g fimction helps identify and classify large segments of 

data. The data mining and data drilling fiinctions qualify these large segments of data to 
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further identify and quantify business opportunities. Once a significant pattern has been 
established, the pattmi can be represented as a mathematical model that establishes the 
corrdation between certain characteristics (e.^., income over $50,000, northeastern U.S. 
population, etc.) to other characteristics (e.^., cellular users). From these models, the 
S BSU 1 1 6 can create mailing lists of candidates for a cellular direct mail campaign. 

The general query fimction allows the BSU 116 to perform simple 
queries of data in the data marts via a DSS user inter&ce process. For example, the 
BSU 116 can query the data mart for the total sales in a given year. The results delivery 
fimction allows the DSS 104 to deliver data in numerous ways, such as formatted 

10 reports, three-dimen^onal graphics, etc. 

Each BSU 1 16 p^orms strat^c queries of data in the data warehouse 
of the DSS 104, using certain analytical tools. From the results of these queries, the 
BSU 116 formulates marketmg campaigns. The BSU 116 then uses CONI 106 to 
implement the selected maiiceting campaign. As described more fully below, the BSU 

15 116 spedfies to COM 106 criteria to use in extracting lead data firom the DSS 104. 
Lead data is used to identify client leads, which are clients to be targeted m the selected 
marketing campaiga A ""lead^ is typically a client who is a potential customer of the 
— , .. . .^.- . company, . Each Jead^is identified by a con-espon^g,. unique ^ c^ 

the DSS 104. CONI 106 then generates leads or lead records by matcWng these client 

20 identifiers with a name, address, and/or telephone number obtained firom CARMA 102 
via an operational data collection/distribution process of DSS 104, described below with 
respect to in Figure 3. 

When CONI 106 generates lead records, it places these records in the 
CLR 108. The CLR 108 is a database, smaller than the data warehouse of the DSS 104, 

25 used to track leads and activities performed on leads. The CLR 108 stores both lead 
records and lead distribution records. Each lead record, stored in the CLR 108, includes 
fields for client identifier, telephone number, address identifier, and perhaps a field for 
previous contact. Figure 4 shows an exemplary, more detailed, lead record constructed 
under Informix, showing nimierous, generally self-explanatory fields. The CLR 108 

30 preferably stores only one lead record per client. The CLR 108 also stores lead 
distribution records. More than one lead distribution record can be associated Mwth each 
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lead record. Figure 5 shows an exemplaiy, more detailed, lead distribution record 
constructed under Informix, showing numerous, generally self-explanatory fields. Each 
lead distribution record includes fields for identifying certain TMZDM centers 118, a 
number of records descend to each center, dates, priority codes, etc. 
5 The lead records generated by COM! 106 and stored in the CLR 108 are 

distributed by CONI to one or more Telemarketing/Direct Mail Centers (TM/DM 
centers) 118. The TM/DM centers 118 inchide call centers fi-om which telemarketing 
agents perform client contacts, sales, and services over the phone. Often, a TMZDM 
center 1 18 is located in each "sales cit/* in which marketing campaigns are conducted. 

10 However, the TMZDM centers 118 can conduct marketing campaigns outside of the 
cities in which they are located. 

The TMZDM centers 1 1 8 may also include centers firom which direct mail 
campaigns arc conducted. While the present invention is generally described below with 
respect to a telemarketing campaign performed at the TMZDM center 118, those skilled 

15 in the relevant art will readily recognize that the embodiment of the present invention is 
equally applicable to direct mail campaigns. Additionally, the present invention is 
equally applicable to other methods of contacting clients, either physically or 

, .dectronically,-s^^ or Internet contact. . ^ 

Agents at the TM/DM center 1 18 use the lead records provided to them 

20 by CONI 106 to call or contact clients and perform sales andZor service fimctions. The 
agents input the results of these contacts to the TMZDM cent«- 1 1 8, which forwards the 
results to COM 106. CONI 106 provides information firom these results back to both 
CARMA 102 and the DSS 104 as a data provider 110. For example, if a client is 
contacted to market to them long distance service, but the client indicates they prefer to 

25 switch their local phone service provider instead, an agent records this mdication in a file 
at the TMZDM center 118. A file of all clients who prefer to switch thdr local phone 
service provider is then fed, as a data provider 110, to CARMA 102 and the DSS 104. 
CARMA 102 uses this information to update the profile of each client included in the file 
to indicate this client is interested in switching their local service provider. This 

30 information is then fed fi-om CARMA 102 to the DSS 104, in the form of a client 
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identifier and an indicator that represents an interest in switching local service providers, 
which is stored therein. 

The DSS 104 can also recdve information directly firom the TM/DM 
center 118 (as a data provider), via CONI 106, indicating how many people in a 
5 particular dty, for example, are interested in switching their local service provider. From 
this information, the BSU 1 16 can query the DSS 104 to determine if enough interest 
exists in a certain city to formulate a local service provider mariceting campaign in the 
dty. CONI 106 can then generate leads for the local sendee provider campaign. The 
above example represents one of many feedback loops within the SaMS infirastructure 
10 100. 

When an agent at the TM/DM center 118 signs up a new customer or 
makes a sale, the agent inputs an order directly into a customer order entry system 120, 
The customer order entry system 120, in addition to recording and provisioning the 
order, provides update data to the DSS 104 to indicate the results of, or information 

15 surrounding, the order. For example, if the order is for long distance swvice, the 
customer order entry system 120 updates the DSS 104 to indicate this client now 
subscribes to long distance service. 
^ . ^ — -ThcL .ord^„ for long distance-service- Js also provided to .National XEC^ ^ 

Interface System (NLIS) and Quick Primary Interexchange Carrier (PIC) systems 122. 

20 The NLIS and Quick PIC systems 122 pro>dde the order to the client's Local Exchange 
Carrier (LEC) 124 so that the LEC can convert the client's PIC at the appropriate local 
Class 5 switch. The NLIS and Quick PIC systems 122 are described in detail in U.S. 
Patent Application entitled "System and Method for Real Time Exchange of Customer 
Data Between Tdecommunications Companies," (attorney Docket No. 1643/00568; 

25 asdgnee Docket No. COS-96-069) and assigned to a common assignee of the present 
application. The architecture of the TM/DM centers 118, customer order entry system 
120, and NLIS and Quick PIC systems 122 enable the processes of contacting a client, 
selling long distance service to that client, recording and provisioning the order for long 
distance service, and converting the client's PIC at the LEC 124 switch to all occur 

30 within only a few minutes. 
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The NLIS and Quick PIC systrais 122 also provide data to the DSS 104 
for unsolidted PIC conversions. If customers of a long distance company switch to 
another company, their PIC conversions wiD be provided by the LEC 124 to the NLIS 
and Quick PIC systems 122. The NLIS and Quick PIC systems 122 provide files of 
5 these conversions to the DSS 104. The DSS 104 in turn stores them, and allows CONI 
106 to extract all recent PIC conversions and generate leads for a customer ^i^back 
campaign. 

The SaMS infrastructure 100 consists of CARMA 102, the DSS 104, and 
CONI 106 as a core. The SaMS infrastructure 100 also uses and can include the CLR 

10 108, TM/DM centers 1 18, customer order entry system 120, and NLIS and Quick PIC 
systems 122 to provide additional functionalities. The SaMS infrastructure 100 also 
allows the use of a BSU 116, providing to the BSU the ability to analyze massive 
amounts of data and formulate marketing camp^gns that are automatically implemented 
via lead generation and provisioning to the TM/DM centers 118. The SaMS 

IS infrastructure 100 is described in greater detail in co-pending U.S. Patent Application 
entided ^Information Architecture For Strategic Marketing Systwns," whidi is filed 
concurrently herewith and assigned to a common assignee of the present applicatiort 

, ... ...^ . ^Referring to.£igure 2,^ exemplary internal architecti^ 

shown. CONI 106 provides a graphical user interfece (GUI) 160 for users to interact 

20 with CONI in at least two ways: to construct lead marts and to perform queries or 
searches within such constructed lead marts. Considering first the query of lead marts, 
users such as a BSU 1 16 of the company, use the GUI to translate a marketing strategy 
into a marketing campaign. Examples of screens displayed by the GUI 160 to the BSU 
1 16 are shown in Figures 7-26, described below. The BSUs 116 select options or input 

25 data via the screens shown in Figures 7-26 in conventional marmer, such as using a 
mouse or keyboard of a computer. 

The BSU 116 first specifies criteria for targeting clients. For example, 
from a prior analysis performed on data in the data warehouse of the DSS 104, the BSU 
1 16 may determine that people who have recently moved from California to Colorado, 

30 and have purchased a car in the past year, are likely to subscribe to cellular service and 
switch their long distance provider. As a result of this determination, the BSU 116 
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wishes to offer a long distance and cellular service package to these people under a 
telemarketing campaign. The BSU 116 uses the GUI 160 to input and specify that it 
wants to pull records of all clients who have (1) moved from California to Colorado, 
(2) have piirchased a car in the past year, and (3) are not currently both long distance 
S and cellular customers of the company. 

A campaign management process 162 receives the input data or criteria 
from the GUI 130 and translates such criteria into a lead qualification fiher or file. For 
example, the campaign management process 162 builds a query from the input criteria 
using structured query language (SQL) statements. The building of a query is described 

10 below with respect to Figures 6, 11, and 15-21. A query to produce a Ust of lead 
records is generally described herein as a "marketing campaign,** as described below. 

A lead qualification filter process 164 recdves the constructed lead 
qualification filter from the campaign managraient process 162 and applies such filter to 
data m the data warehouse of the DSS 104 or in a lead mart 166 (discussed below) to 

IS extract a list of clients \^ch meet the criteria specified by the lead qualification filter. 
The lead qualification filter process 164 employs the lead qualification filter to extract 
client records as "lead records" for a given marketing campaign, and stores such lead 

In the previous example, the lead qualification filter may first extract a 
20 first lead list of all client identifiers for clients who have moved from California to 
Colorado, ihen from this first list extract a second lead list of all clients who have 
purdiased a car in the past year. From this second list, the lead qualification filter then 
extracts a third, smaller lead list of all clients who are not currently both long distance 
and cellular customers of the company. The lead qualification filters may also extract 
25 other undesirable leads, such as clients who have requested to not be contacted 
("suppressions") or clients whose age is greater than 100 (/,e,, probably deceased). 

In general, queries and retrieval of selected data from databases, data 
marts, and data warehouses under the exemplary embodiment of the present invention 
are performed using known database querying and retrieval techniques, such as using 
30 SQL statements and open database connectivity (ODBC), as is known by those skilled in 
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the relevant art. Thus, to avoid obscuring important aspects of the present invention, 
such details are generally omitted hereiit 

The lead qualification fiher process 164 also constructs lead marts 166 in 
which to store the data extracted fix>m the DSS 104 based on certain lead qualification 
S filters. ""Lead marts" 166 are databases, smaller than the data warehouse, which contain 
subsets of data fi'om the data warehouse. In general, the lead marts 166 are customized 
collections of data extracted firom the DSS 104 for indi^ddual BSUs 116. As is described 
herein, the BSUs 1 16, in turn, query the lead marts to develop spedfic client lists for a 
given marketing campaign. 

10 Each lead mart 166 is typically a single-subject database used by 

individual groups of users, such as individual BSUs 1 16 in the company. Examples of 
such lead marts 166 for a long distance company, in a preferential order, can be a lead 
mart storing data of all customs of international alliances on partner programs (e.^., 
fixquent flyer programs), a lead mart storing data of all customers who make firequmt 

15 international calls to non-English-speaking countries, a lead mart with all customers who 
make firequent international calls to English-speaking coimtries, a lead mart of all 
previous customers who have recently switched to another long distance company, and a 
„ iMss^^^ service. These common lead . . 

marts 166 can be used to manage ongoing marketing campaigns. For example, a lead 

20 mart 166 of all previous customers who have recently switched to another long distance 
company would be vary usefijl for managing an ongoing customer win-back campaign. 
The lead marts 166 may be embodied in a separate computer, such as a Sun Box, 
manufactured by Sim Microsystems, but do not need to be. 

In the exemplary embodiment, the lead qualification filter process 164 

25 provides a preferential order or hierarchy of lead marts 166 so that a given client is not 
identified in more than one lead mart (and thus not contacted repeatedly under various 
marketing campaigns). For example, the lead mart 166 of customers of international 
alliances/partnerships has a higher ranking than the lead mart of customers who make 
international calls to English-speaking countries. 

30 The lead qualification filter process 164 can be setup to perform nominal 

or periodic processing. For example, the lead qualification filter process 164 can be 
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created to perform repeated data extraction from the DSS 104 based on a previously 
created lead qualification filter. Thus, on a periodic baas (e,g,, daily), the lead 
qualification filtw process 164 periodically queries and extracts client records fi-om the 
DSS 104 (via data warehouse shipping (described below)) that satisfy the lead 
5 qualification filter, and updates the corresponding lead mart 166. Thus, the lead marts 

166 continuously have currently updated data stored therdn. 

The user or BSU 116 also uses the GUI 160 to input data or lead 
inventory specifications for creating spedfic client lists for implraienting a given 
mariceting campaign. For ©cample, the user may input data to the GUI 160 specifying 
10 how many lead records are to be formatted each day, to which TMZDM centers 118 
certain lead records should be distributed, etc. A lead inventory management process 

167 receives such input data from the GUI 160 and uses the data to manage the 
extraction of and processing lead records from the lead marts 166. Thus, in a manner 
similar to that for the lead qualification filter process 164, the lead inventory 

15 management process 167 constructs a query based on data received from the GUI 160 
and extracts lead records stored in one or more of the lead marts 166 based on a given 
marketing campaign to produce a "lead list" or list of lead records selected based on the 

. ~ given jnaAet^ The lead inventory. riianagemait process. 167 stores-. the 

resulting lead list and corresponding lead records in the CLR 108. 

20 While the lead list typically includes a list of lead records, each lead 

record indudes not only the client identifier for a given lead, but also additional 
information regarding the client, such as a number of times, and assodated dates, when 
the client was contacted, and a code number corresponding to a marketing campaign 
during which the client was contacted. Generally, leads or clients can be tracked within 

25 COM 106 based on a marketing campaign code created when a marketing campaign is 
created. Furthermore, the lead inventory management process 167 stores lead 
distribution records for each marketing campaign. The lead distribution records identify 
which TMZDM center 118 a given lead record is to be distributed (or has been 
distributed). More than one lead distribution record can be assodated with one lead 

30 record, since a cUent imder the lead record can be assodated with more than one 
mariceting campaign. The lead inventory management process 167 creates lead 
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distribution records for the gjven marketing campaign which specifies how many lead 
records are to be formatted each day, to which TM/DM centers 118 certain lead records 
should be distributed, etc. 

The lead inventory managment process also performs certain screening 
S processes such as ensuring that duplicate client records are not retrieved and stored in 
the CLR 108. The lead inventory management process 107 ensures that a given cUent is 
not identified in two separate marketing campaigns (and thus is not called twice). The 
lead inventory managmient process 167 flags each client identified under a lead list in 
the CLR 108. If a subsequent lead list identifies a client already flagged in the CLR 108, 

10 the lead inventory management process 167 compares a hierarchy or rating of the new 
lead list to that of the former lead list which previously flagged the given client. If the 
subsequent lead list has a higher ranking than the prior lead list, then the client is flagged 
for the new lead list. Thereafter, the lead inventory management process, via a formatter 
(described below), cancels a lead record previously forwarded to the TMZDM center 118 

15 under the prior lead list. Thus, the lead inventory management process 167 can 
dynamically adjust ongoing marketing campaigns so that more successfiil campaigns 
(higher priority campaigns) preside over and accumulate clients fi'om other campaigns. 

V - ln.&en$!ljal, COJJI 106 provides two types of data retrieval granularity to 

the BSUs 116. Under a coarse granularity, the BSU 116, through the GUI 160, 

20 campaign management process 162 and lead qualification filter process 164, extract a 
subset of client data firom the DSS 104, and stores such data in a lead mart 166. In a 
finer granularity process, the BSU 116, through the GUI 160 and processes 162 and 
164, develop a subset of client data stored in a lead mart 166 to produce lead lists and 
extract lead records for certain marketing campaigns. 

25 Summarizing, the campaign management process 162 creates lead 

qualification filters based on queries or criteria input by the BSU 116. The lead 
qualification filter process 164, in turn, implements such created lead qualification filters 
to extract the appropriate data fi'om the DSS 104 (to construct lead marts 166) or fi'om 
the lead marts (to construct lead lists). The campaign management process 162 provides 

30 an interface between the GUI 160 and the lead qualification filters process 164, while the 
lead qualification filters process interacts with the databases/data warehouses. 
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A formatter process 168 receives client data that is extracted Scorn the 
CLR 108 and DSS 104 based on a lead list for a ^en marketing campaign. The 
formatter process 168 matches the client identifier of each entry in the lead list with a 
name» address Of for a direct nuiil campaign), and telephone nimiber Qf for a 
S tdemailceting campaign) to create an appropriate lead record to be ultimately used to 
contact the client. The formatter process 168 obtains the rmme, address, and telephone 
number assignments for client identifiers firom CARMA 102 via the DSS 104. As shown 
in Figures, the DSS 104 includes an operational data store (described bdow) that 
extracts this information firom CARMA 102 and feeds it to CONI 106. 

10 The formatter process 168 formats the resulting leads into lead records, 

and lead distribution records that include an identification and address of spedfic 
TM/DM centers 118 to which each lead record is to be distributed; this information is 
provided by the lead inventory management process 167. The formatter process 168, in 
the exemplary embodiment, is table driven, and thus employs definition files, similar to 

IS templates. Such definition files spedfy the location of data retrieved by the formatter 
process 168 for display to agents at the TM/DM centers 118. For example, the 
definition file can specify that column 1 include phone numbers, column 2 include names, 
0^9, By being table driv5?n, the fonnatter propess. 168 does not require underiying code, 
to be changed if a given lead record format is to be changed. Instead, only the definition 

20 file needs to be changed in order to change the way in which data extracted firom the 
DSS 104 is displayed to agents at the TM/DM centers 1 18. 

The TM/DM centers 118 receive formatted lead records firom the 
formatter process 168. Agents at the TM/DM centers 1 18 then contact clients identified 
in such records and record the results of such contacts. 

25 A contact management process 169 receives the results of the contacts 

fi-om the TM/DM centers 118. In the exemplary embodiment, the results of such contact 
conast of, or include, certain predetermined codes. Such codes indicate whether a climt 
is to be a suppression, whether the cUent is to be contacted agmn and at what time, and 
any changes to be made to the client's profile. Thus, the contact management process 

30 169 arranges a follow-up with a lead if needed, updates stored data, etc. The contact 
management process 169 forwards the code and or information to the data warehouse of 
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the DSS 104 for storage. The contact management process 169 thereby provides 
feedback on the results of the marketing campaign. The feedback provided by the 
contact management process 169 provides historical information to CONI 106. Such 
historical data can be accessed, via CONI 106, by the BSU 116 to determine how 
S successful a given marketing campaign is. The BSU 116 can then modify a given 
marketing campaign to help unprove its success, if needed. 

Figure 3 iUustnites steps under a typical data flow for collecting and 
storing marketing data, and using that data to formulate and implement a marketing 
campaign, in the SaMS infrastructure 100. Process steps or data flow in Figure 3 is 
10 identified by reference numbers 1 through 24. Paragraphs below are introduced by a 
nimiber, 1 through 24, which corresponds to the data flows shown in Figure 3. Where 
relevant, certain hardware or processes are also desoibed with respect to the data flows 
1 through 24. 

1. Client information fi-om the data providers 110 is collected by 
15 CARMA 102. As noted above, the client information fi-om the data providers 110 can 

include internal data sources such as the company's customer traffic, billing system 
records, client contact records, etc., as well as external data such as syndicated lifestyle 
irfpnriation, CARMA 102 is designed to accept data in pi:actically any format and firom 
any source. CARMA 102 uses input client information to update client profiles in its 
20 client database. 

2. Any changes to client profiles in CARMA 102 (generally a result 
of new client information input by the data providers 1 10) are captured and fed to the 
DSS 104. Spedfic client identification data, such as names and addresses, are withheld. 
Instead, CARMA 102 provides generic client identifiers to the DSS 104. The DSS 104 

25 uses a data harvesting process 170 to collect and format all input data, whether firom 
CARMA 102 or any other data provider. The data harvesting process 170 mcludes 
processes for identifying, extracting, transforming, deriving, aggregating, integrating and 
conducting integrity checks of data collected firom the data providers 1 10. 

The identifying process identifies what data elements within the collected 

30 data are needed for downstream processes, as well as identifying a definitive source for 
collected data, not necessarily the first known source. The extracting process copies 
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appropriate data from the data providers 110, The transforming process reconciles the 
various ways that the same data is labeled as it is recdved from the data provides 1 10. 
For example^ values for a client*s sex under one data provider or system may be in the 
fonn of "m" or "f while from another data provider be in the form of "r or "2." The 
5 transforming process may instead assign a new value, such as "male" and "female." 

The deriving process converts some data into anoth^ vahie. For 
example, two or more fields of data about a client may be converted to a score (e.^., the 
address and income of a client combined and represented by a two-digit score). The 
aggregating process combines and summarizes data across a set of transactions or a set 

10 of individual clients. For example, the total monthly long-distance spending by a client 
may be aggregated over a year to provide an average monthly spending value for that 
client. The integration process matches data with the appropriate client number, and 
verifies time firames for each piece of data. The integrity check process ensures that data 
stored in the data warehouse is in the appropriate form/format. 

15 3. The data harvesting process 170 collects from various data 

providers 110 information for which specific client identification is not needed. This 
information can be used to identify general trends. 

4. - The data harvesting process 170 stores all the data it collects in a 

data warehouse 172. The data warehouse 172 may be partitioned and configured in 

20 various schemes to suit the needs of the business utilizing it. For typical businesses, such 
as a telecommimications company, it must be capable of storing huge volumes of data, 
perhaps several Terabytes. The data warehouse 172 pref^ably employs a massive 
parallel processing (MPP) platform, such as more than 100 IBM SP2 processors. A 
scaleable database management system is preferably used, such as that offered by 

25 Informix Corporation. 

5. and 6. A data shipping process 174 extracts specific data from the 
data warehouse 174 and places this data in data marts 175. The data marts 175 are 
smaller databases that house subsets of data from the data warehouse 174, and are used 
to facilitate quick and easy access to the data stored in the data warehouse. The data 

30 marts 175 each preferably employ symmetrically parallel processor (SMP). Each data 
mart 175 is setup for an individual customer or user of the DSS 104. For example, one 
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data mart 175 can be established for a residential marketing BSU 1 16, and another data 
mart established for a small business group BSU 1 16. 

A user of the DSS 104. such as a BSU 116, specifies in the data shipping 
process 174 what data they wish to have placed in their data mart 175 from the data 
5 warehouse 172, and when. The BSU 1 16 specifies such criteria via a DSS user interfece 
process 176 (described below). The data shippmg process 174, on a periodic basis, then 
extracts data firom the data warehouse 172 under the user's spedfied criteria, and places 
this data in the user's data mart 175. Summarizing, the data shipping process 1 74 moves 
data Srom the central data warehouse 172 to departmental data marts 175 in a process 
10 amilar to the data harvesting process 170 (e.g., users can select requested elements and 
require additional transformations be applied to data before it is stored ui the data 
marts). 

7. and 8. The DSS user interface process 176 is a tool that provides 
access to and analysis of data in the data marts 175. Users, such as a BSU 1 16, use the 

15 DSS user interface process 1 76 to perform queries into the data in their data mart, under 
a query process similar to that described above for CONI 106. For example, the data 
shipping process 174 may extract firom the data warehouse 172 data representing all 

clients who. have recently moved to the United States fi^om a foreign country, and place^ 

this data in one of the data marts 175 for the BSU 116. The BSU 1 16 then uses the 

20 DSS user interface process 176 to obtain a list, fi-om this data, of all of these clients who 
moved to California fi-om Japan, and have selected another long distance company. 

Generally, more complex methods of analysis are used to determine what 
types of marketing campaigns can be successfiil. The BSU 116 examines their data mart 
175 to find significant patterns and relationships that can be translated into marketing 

25 strategies. Using the DSS user interface process 176, the BSU 116 formulates queries 
and performs the necessary analysis of data in their data marts 175 to develop marketing 
strategies and therefi-om determine what sort of marketing campaigns to implement. 
Queries against data in the data warehouse 172 are made using SQL or other query 
language. 

30 The BSUs 116 preferably includes minicomputers or workstations, such 

as Sun Microsystems SC2000/SPARC20 system. Such microcomputers preferably 



wo 98/49641 



PCTAJS98/06721 



21 

operate under a UNIX operating system, and run a database management system such as 
that offered by Informbc. The minicomputers (as well as other elements \'^dthin the SaMS 
infiBstructure 100) are coupled using high-bandwidth connections. For exanq)Ie, the 
minicomputers of the BSUs 116 are preferably coupled to the DSS 104 and CONI 106 
S using fiber-optic distributed data interface (FDDI) local-area network connections. The 
minicomputers preferably communicate to the infirastructure 100 using ODBC. 

The BSUs 116, in the exemplary embodiment, employ a Worid Wide 
Web browser to access hypertext markup kmguage (HTML) applications on the DSS 
104 and/or CONI 106. The HTML applications provide a menu of data views and other 
10 screens, under a GUI environment (to the BSU 116), as described herein. Thus, the 
BSUs 116 access portions of the SaMS Infiastructure 100 via an intranet, or via the 
Internet. 

9. Once the BSU 1 16 has analyzed data and determined a marketing 
strata, they use CONI 106 to implement that strategy as a marketing campaign that b 

15 targeted for a specific cUent segment. The campaign management process 162 and GUI 
160 within CONI 106 provide the ability for the BSU 116 to state their mariceting 
campaign as spedfic criteria. 
. , . VQ.^ to. the campaign management- 
process 162 is converted by the campaign management process into lead qualification 

20 filters under the marketing campaign. The lead qualification filters are then input to the 
lead qualification filters process 164. The lead qualification filters process 164 is the 
interfece between the data shipping process 174 of the DSS 104 and CONI 106. The 
lead qualification filters specify criteria that clients need to meet in order to be included 
in the marketing campaign. 

25 II. The lead qualification filters process 164 extracts data firom the 

data warehouse 172 based on criteria that represents the BSU 1 16's marketing campaign 
(under the lead qualification filter). Alternatively, the lead qualification filters process 
164 applies the lead qualification filter to extract data stored in the lead marts 166. 

12. Client records that meet all lead qualification filter criteria are 

30 placed in the lead marts 166 as related lead records. The lead marts 166 are CONI 106 
data marts housing client records or lead records for particular nuirketing campaigns. 
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From the lead records, formatted lead records will be generated (as discussed herdn). 
There may be multiple lead marts 166, but only one record of a single client is preferably 
stored in one of them. 

13. The lead inventory management process 164 creates a lead list 
S based on the lead records selected by the lead qualification filter Additionally, the lead 
inventory management process 164, under direction fix>m data mput from the BSU 116, 
creates lead distribution records that spedfy the number of lead records to make 
available for calling or mailing, specify which TM/DM centers 118 receive each lead 
record, spedfy whole numbers of lead records to assign to eadi TM/DM crater, etc. 

10 The BSU 116 can use the lead inventory management process 164 to spedfy \i^ere 
leads are to be sent, based on agent skill sets, geography, resources available, etc, 
thereby allowing the TM/DM centers 1 18 to manage their resources better. The lead 
inventory management process 164 also ensures that each client is extracted only once 
fix>m all of the lead marts 166, ensuring no client duplication in various lead lists. 

15 14. The lead inventory management process 164 feeds the lead list 

and assodated lead records and lead distribution record for storage in the CLR 108. 
The CLR 108 maintains lead records for each client throughout the marketing campaign, 
. to^^ contacts and .results of contacts under the . feedback data^^aws 

described herdn. The lead inventory managanent process 167 tracks leads on clients 

20 that have recently been provided to a TM/DM craters 1 18, to ensure fi^uent contacts 
are not made to the same client and updates lead records in the CLR 108 accordingly. 
For example, if a lead record on a specific client is passed to a first TM/DM center 118 
on one night, and another lead record on the same client is provided to CLR 108 from 
the lead inventory management process 167 the next night, the lead record in CLR 108 

25 will dther indicate on the second lead record that this is a second lead record for the 
same client in two nights, or an indication will not pass this lead to another TM/DM 
center 118. 

15. The DSS data harvesting process 170 collects from CARMA 102 
a feed of specific data associated with or assigned to client identifiers such as name, 
30 address, and telephone numbers. 
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16. This specific data is placed in an operational data store (ODS) 
178. The ODS 178 is similar to the data warehouse 172, but is generally much smaller. 
A purpose of the ODS 178 is to store data tenq)orarily» in ord^ to distribute data to 
other processes or systons. 
S 17. and 18. Upon request by the formatter process 168, the data shipping 

process 174 extracts firom the ODS 178 the specific data, such as the name, address, and 
telephone number, assigned to the client identifiers in the lead records, and provides this 
data to the formatter process. The formatter process 1 68 uses this data to as^gn a name 
and telephone number, and possibly a mailing address, to each client identifier that was 
10 provided by the lead inventory management process 164, and create formatted lead 
records. 

19. The formatter process 168 retrieves the lead records assodated 
with the lead list firom the CLR 108 and constructs formatted lead records using the 
client data provided by the data shipping process 174. Formatted lead records may 
IS include some or all of the following data: client names, telephone nimibers, addresses, 
contact history, TM/DM centers 1 18 assignment, and other information pertinent to the 
marketing campaign. The formatter process 168 formats lead records by matching client 

idjsntifiers, which B^^j^^y^ by the. lead inventory management process 164, .with 

names and telephone numbers fi^om CARMA 102. 
20 20. The formatter 168 forwards the formatted lead records to the 

appropriate TM/DM centers 118 based on the lead distribution list. The TM/DM 
centers 118 import such lead records and contact the clients and conduct the marketing 
campaign, such as offering long distance services or products. 

21. The results of each client contact are recorded locally at the 
25 TM/DM centers 118. 

22. The results of each client contact are extracted by or forwarded to 
the contact management process 169 within COM 106 fi-om the TM/DM center 118. 
The contact management process 169 can arrange follow-up leads and report on status 
or results of a given campaign. The contact management process 169 may automatically 

30 update lead records stored within the CLR 1 08. 
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23. The contact management process 169 provides results of client 
contacts to the data harvesting process 170, so that the data warehouse 172 can be 
updated with these results. The data shipping process 174 then updates the 
corresponding data in the data marts 175. This represents another of many feedback 

S loops built into the SaMS infiastructure 100. As noted above, the BSU 1 16 formulates 
and conducts a marketing campaign. The results of each client contact under the 
campaign are fed to the data warehouse 172. The BSU 116 can then extract and analyze 
the results of the overall campaign by spediying to the data shipping process 174 an 
extraction of certain client data. From this, the BSU 116 may formulate another 

10 campaign, modify an existing campaign, or identify an imexpected response to the 
previous campaign. 

For example, the BSU 116 may formulate a campaign to sell long 
distance service to a certain RBOC's customers. Many customers, when contacted by a 
TMZDM center, may respond with a preference to switch local service providers. These 

15 responses are recorded in the CLR 108, extracted by the contact management process 
169, collected by the data harvesting process 170, and stored in the data warehouse 172. 
The BSU 116 then analyzes the results of their campaign via the DSS user interface 
process 176, a^^^ upd^ed data marts, and determines that a local service 

marketing campaign to those same customers is needed. 

20 The TM/DM centers 118 can also perform direct mail campaigns. For 

example, CONI 106 can instruct the TMZDM center 118 to mail brochures to selected 
clients, wait two weeks, then call those clients. 

24. The result of a client contact may be that the client requests to not 
be called again (a "suppression"). As noted above with respect to data flow 22, the 

25 contact management process 169 updates the lead records in the CLR 108 to indicate a 
suppression for the client. An extraction of all suppressions are then fed, as a Data 
Provider, to CARMA 102. CARMA 102 in turn will feed these suppressions, by client 
identifier only, to the data warehouse 172. The lead qualification filter process 164 can 
then filter out any clients with a suppression indicator in future campaigns. Suppressions 

30 can also be provided to CARMA 102 from External Data Sources 1 14, such as a LEC 
124. 
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The campaign management and lead inventoiy processes will now be 
described with respect to the exemplary flowchart of Figure 6. Figure 6 shows an 
overall process 200 performed by the campaign management process 162 and lead 
inventoiy management process 167. Associated with each step or subprocess in 
5 Figure 6 are exemplary screens displayed by the GUI 160 to the BSU 116. Such 
screens^ shown in Figures 7-26, are preferably built using ^ficrosofl Visual Basic. As 
described bdow, the screens shown in Figures 7-26 are referred to by the same reference 
numeral for the corresponding steps under the process 200. If multiple screens are 
associated with a given step, then the screens are represented by the ref^ence nimieral 

1 0 followed by letters A, B, C, 

In step 202, the process 200 displays a log in screen, as shown in 
Figure 7. The log in screen requests a user ID, and password for the user. In the 
exemplary embodiment, three levels of users are permitted access to the infrastructure 
100. A highest priority user can access all aspects and processes of the infirastructure 

IS 100. A mid-level user can submit lead generation queries, create lead qualification 
filters, and perform many fiinctions within the infi:astructure 100. A low level user can 
simply view certain data. The following discussion assumes that the user has access to 

dl process^ de&^ _ . ^ ^ , , _ 

In step 204, after successfiil log in, the process 200 displays a main menu 

20 screen (Figure 8) which permits the user to select one of at least sbc subprocesses: 
Anewing or modifying lead marts (step 206; Figure 10), viewing or generating leads (step 
208; Figure 1 1), viewing records m the CLR 108 (step 210), \dewing tables of data (step 
212; Figure 12), performing security fimctions within CONI 106 (step 214; Figure 26), 
or creating reports (step 216). The main menu, step 204, also provides certain pull- 

25 down functions (in a Windows environment). For example, as shown in Figure 9, the 
main menu (step 204) can provide a generic table to view columns or rows of data 
within CONI 106 or other portions of the infrastructure 100. As shown in Figure 9, the 
user can determine the status of a particular lead, perform local and global queries of 
leads or records within one or more databases within the infirastructure 100, determine a 

30 distribution status of records, display tables of steps necessary to create lead 
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qualification filters, generate rqports, count the number of records in a lead mart, 
determine the status of records in a lead mart, etc. 

Based on a first selection fi'om the main menu screen (Figure 8), the 
process 200 in step 206 displays an initial lead mart screen, as shown in Figure 10. 
5 Under the lead mart s^een of Figure 10, the user can open an existing table previously 
build to ideate a lead mart, or create a new record for storage m the lead mart. 
Figures 27A and 27B together show an exemplary mart table used to create a lead mart 
under Informix, and fields in the table are generally self-explanatory. 

In step 218, the user can select one of two tabs for options to manage 

10 properties of the lead marts, as shown in the screens of Rgures 13 and 14. Referring to 
Figure 13, a first screen 218A allows the user to view a sunmiary list of all of the lead 
marts being built. Referring to Figure 14, a screen 21 8B displays tables of the lead marts 
and allows the user to o-eate a hierarchy among such lead marts by promoting or 
demotmg the marts with respect to each other. 

IS In step 208, the process 200 displays a corresponding screen that permits 

the user to input a query or profile to be used in creating a lead qualification filter under 
a marketing campaign. In step 220, the process 200 displays a screen 220A, shown in 
Figure .15, that allows the user to. input distribution criteria, used to. create a lead 
distribution list. As shovm in Figure 16, the step 220 also displays a soreen 220B that 

20 allows the various sale cities or TM/DM centers 1 1 8 to be displayed with corresponding 
data. In step 222, the process 200 displays a corresponding screen shown in Figure 17 
that permits the user to save a constructed query, submit the query to the lead 
qualification filter process 164 to pull corresponding records, and a fi-equency of refiresh 
of such records. 

25 In step 224, the process 200 allows the user to display or obtain reports 

on various marketing campaigns. Referring to Figure 18, a screen 224 A allows the user 
to display lead records pulled for a given marketing campaign. Referring to Figure 19, a 
screen 224B displays a total number of lead records (rows), records which foiled the lead 
qualification filter, duplicates that pass the filter, but are already located in the CLR 108 

30 (under another campaign) and those which passed under the filter/campaign. Referring 
to Figure 20, a screen 224C displays distribution information to the user based on his or 



wo 98/49641 



PCTAJS98rt)6721 



27 

her submitted query. Referring to Figure 21, a screen 224D displays errors in pulling 
lead records under the query. 

In step 212, the process 200 displays a corresponding screen, shown in 
Figure 12, that provides four options for displaying tables of data to the user sales 
S dty/media/fonns table, distribution default table, list code hierarchy table and 
miscellaneous table. Referring to Figare 22, a screen 226A displays or allows the user to 
create a record for a new sales city. Referring to Figure 23, a screen 226B allows the 
user to select one of several forms for displaying lead records to the sale city (TM/DM 
center 118). Referring to Figure 24, a screen 226C allows the user to specify the type of 
10 media on which lead records are distributed to the sale cities (e,g., disk TRANS, Uq>e, 
etc.). 

In step 228, the process 200 permits the user to select one of several 
distribution formats under previously constructed lead distribution records. In step 230, 
the process 200 displays a corresponding screen, shown in Figure 25, that lists codes 
15 corresponding to the hierarchy of marts and their corresponding lead records. In step 
232, the process 200 displays any additional tables of information for user selection by 
the user. 

In.step.214, the process 200 displays a corresponding screen, shown -in - ^ 

Figure 26, of security options provided under COM 106. Access to various portions of 

20 COM 106 and its processes can be limited to levels of users. 

Although specific embodiments of; and examples for, the present 
invention are described herein for illustrative purposes, various equivalent modifications 
can be made without departing firom the spirit and scope of the invention, as will be 
recognized by those skilled in the relevant art. The teaclungs provided herein of the 

25 present invention can be applied to other businesses and marketing campaigns, not 
necessary the exemplary telecommunications service provider and telemarketing 
campaign desoibed above. For example, the present invention is eqiuilly applicable to 
implementing marketing campaigns for other market segments, and contacting clients 
developed under such campaigns via the Internet. Moreover, aspects of the present 

30 invention can be employed to generate organized reports based on complex and 
voluminous data stored in a data warehouse. 
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All U.S. patents and applications dted herein are incorporated by 

refer^ce. 

Those skilled in the relevant art can create source code for the software, 
processes and functions described herein based on the above-detailed description of the 
S data flows, fiinctions and processes of the SaNfS Infrastructure and its related 
componmts. While certain operations under the present invention are described as 
occurring genially in a serial fashion, those skilled in the relevant art will recognize that 
it is entirely within the scope of the invention to conduct some operations more or less 
simultaneously, or even in altanate order, from that described herem. 

10 These and otha* changes can be made to the invention in ligjit of the 

above detailed description. In general, in the following claims, the terms used should not 
be construed to limit the invention to the specific embodiments disclosed in the 
specification and the claims, but should be construed to include any data processing 
sj^em that operates imder the claims to provide information managemrat, contact 

15 services and client management functions. Accordingly, the invention is not limited by 
the disclosure, but instead its scope is to be determined entirely by the following claims. 
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CLAIMS 

1. A computer implemented method of generating leads for a marketing 
campaign from client records stored in a data warehouse, the method comprising the steps of: 

oreating a mart containing a subset of the client records stored in the data 

warehouse; 

selecting a subset of the client records contained in the mart based on a first 

query, and 

constructing lead records based on the selected subset of the client records and 
additional information stored in the data warehouse. 

2. The method of claim 1 wherein the step of creating includes the step of 
creating a filter that determines which client records in the data warehouse are contained as 
the subset in the mart. 

3. The method of claim 1 wherein the step of selecting includes the step of 
creating a lead qualification filter that determines which client records in the subset of the mart 
are selected. 



4. The method of claim 1 wherein the step of constructing includes the 
step of retrieving certain data in the client records m the data warehouse based on a client 
number. 

5. The method of claim 1 wherein the step of constructing includes the 
step of formatting the lead records for display on a computer screen. 

6. A system for generating lead records for a marketing campaign based 
on client records stored in a database, the system comprising: 

a user interface unit configured to accept query commands from a user; 
a campaign management unit coupled to receive the query commands and 
create a lead qualification filter. 
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a lead qualification filter unit coupled to the database and coupled to receive 
the lead qualification filter, wherein the lead qualification filter unit is configured to apply the 
lead qualification filter to the client data to extract selected client records; 

a lead management unit coupled to receive the selected client records, wherein 
the lead management unit is configured to apply predetermined rules to the selected client 
records to produce a set of lead records; and 

a formatter unit coupled to receive the set of lead records, wherein the 
formatter unit is configured to convert the lead records into formatted lead records for use in 
the marketing campaign. 

7. The system of claim 6, fiirther compri^g a lead data mart coupled to 
the lead qualification filter unit and the lead management unit, wherdn the user interface unit is 
configured to accept a profile, and wherein the lead qualification filer unit is configured select 
client records in the database for storage the lead data mart based on the profile. 

8. The system of claim 6, fiirther comprising a lead data mart coupled to 
the lead qualification filter unit and the lead management unit, and wherem the lead 
qualification filer unit is configured extract the selected client records, in the lead data mart 
based on the lead qualification filter. 

9. The system of claim 6, fiirther comprising a contact management unit 
coupled to the database and coupled to receive client data for one of the formatted lead 
records corresponding to one of the selected client records, herein the contact management 
unit is configured request the database to alter the one client record based on the received 
cUent data. 

10. The system of claim 6, fijrther comprising a centralized lead data 
repository that stores the set of lead records and a lead data mart coupled to the repository 
and coupled to receive client data for one of the formatted lead records corresponding to one 
of the set of lead records, wherein the contact management unit is configured alter the one 
lead record based on the received client data. 
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11. The system of claim 6 wherein the formatter unit is coupled to the 
database and receives data from the database corresponding to eadi lead record in the set of 
lead records to produce the formatted lead records. 

12 The system of claim 6 wherdn the user int^iace luiit is configured to 
receive commands from the user via the Internet. 

13. A computer-readable medium holding computer-executable instructions 
for perfomung a method comprising the computer-implemented steps of: 

creating a mart containing a subset of client records stored in a data warehouse; 
selecting a subset of the client records contained in the mart based on a first 

query; and 

constructing lead records based on the selected subset of the client records and 
additional mformation stored in the data warehouse. 

14. The computer readable medium of claim 13 wherein the step of creating 
includes the step of creating a filter that determines which client records in the data warehouse 
are contained as the subset in the mart. 

15. The computer readable medium of claim 13 wherein the step of 
selecting includes the step of creating a lead qualification filter that determines which client 
records in the subset of the mart are selected. 

16. The computer readable medium of claim 13 wherein the step of 
constructing includes the step of retrieving certain data in the client records in the data 
warehouse based on a client number. 

17. The computer readable medium of cljum 13 wherein the step of 
constructing includes the step of formatting the lead records for display on a computer screen. 



wo 98/49641 



PCTAJS98/06721 



32 

18. In a computer system having a database holding client records that hold 
information regarding clients for mariceting contact^ a method comprising the computer- 
implemented steps of: 

creating a subset of lead records from the database of client records, wherein 
each lead record in the subset contains less data than a corresponding client record in the 
database; 

selecting a plurality of lead records from the subset; 

retrieving additional information from the database based on the selected 
plurality of lead records; and 

creating formatted records for marketing contact from the additional 
information and the selected plurality of lead records. 

19. The method of claim 18, further comprising the step of forwarding the 
fonnatted records to a mariceting terminal for display thereon. 
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cintjd integer, 
adrjd integer, 
btn_npa smallint, 
btnjxx smallini, 
btn_line smallini, 
division integer, 
account char(8). 
acctjnst.date date, 
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dr.datemoiLI dote, 
drjeadapp_l ctiar(3), 
drjeadcamp.l chorTS), 
dr_mailapp_l ctiar(3\ 
dr_mailcamp_1 ctiar(3), 
dr_mailterm_l charf3|, 
dr_company_2 ctiar(3), 
dr_datesent_2 date, 
dr_datemoiL2 date, 
drjeadapp_2 chqr(3), 
drjeadcamp_2 char(3), 
dr_mailapp_2 ctiar(3Y 
dr_mailcamp_2 char(3), 
dr.mallterm_2 char(3), 
dr_company_3 ctiar(3), 
dr_datesent_3 date, 
dr_datemaiL3 date, 
dr_leadapp_3 char(3), 
drjeadcamp_3 ctiarfS), 
dr_mailapp.3 cttar(3), 
dr_mailcamp_3 char(3), 
dr_mailterm_3 cttar{3|, 
dr_company.4 ct)ar(3), 
dr_datesent_4 date. 
dr_datemaiL4 date, 
dr_leadapp_4 char(3^, 
drjeadcamp_4 chari3), 
dr_mailapp_4 char(3), 
dr_maiicamp_4 char(3), 
dr_mailterm_4 char(3), 
epsiion.use.score smallint, 
fgb_dom_min_c char(1). 
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fgbJntLmin.c char(1), 
fgb_doLc ct)ar(l). 
fgd^canceLdate date, 
fgd.dom_min_c char(1), 
fgdjntl_min_c ctiar{1), 
fgd_mkt_strgty char(l), 
fgd_doLc ctiar(1), 
frmr.cust.type ctiar(1), 
frmr_cust_usage char(l). 
inbound^country char(3), 
inbound JntLmin.c char(1), 
interlato_pic_fr2 ctiar(1), 
interiato^svc ctiaii[l), 
intLdoLc ctiar(1), 
intLlang_value charf2). 
InW^scoreJang ctiar(l), 
IntLtm_score smallint, 
IntLusoge^score smallint. 
interstate_min_c cltar(1), 
interstate_doLc cliar(1), 
intralata^svc ctiar(l), 
intralata1_score smallint, 
intrastate_min_c char(l), 
mtra$tate_doLc char(l), 
invoice.amount integer 
urisdictionjnd char(1), 
language ctiar(1), 
line.size integer, 
istcode.1 charfe^ 
istcode_2 char 6), 
istcode_3 char(6), 
Ist^cbn^datesent date, 
st.cbn_datecall date, 
st_cbn_saleapp ct)ar(3), 
lst.cbn_salecamp char(3), 
ist_cbn_saleterm char(3), 
lst_cbnjeadapp char(3y 
lst_cbnjeadcamp ctiar(3), 
lstJnvoice_montti smallint. 
Ist_mci_datesent date, 
lst_mci_datecall date, 
st_mci_saleapp char(3), 
st_mci_salecamp char(3), 
st_mci_saleterm ctiar(3), 
st_mcijeadapp ctiar(3), 
lst_mcijeadcamp ctiar(3), 
lst_smn_datesent date, 
lst_smn_datecall date, 
st_smn_saleapp ctiar(3\ 
st_smn_salecamp char(3), 
st_smn_saleterm char(3), 
Ist.smnjeadapp char(3], 
Ist.smnjeadcamp ctiar(3), 
mercatus_use_score smallint, 
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mkLmessJntra char(1), 
niche.code char(3)» 
nocall char(1), 
nomcil chanlV 
novisit charfl), 
outbnd_country char(3)i 
outbnd Jntl_min_c char( 1 ), 
pager.crediLscore smallint, 
pager.avail char(1), 
pager_svc char(1), 
personaL800_svc char(1), 
pic_envjnd char(2), 
plan char(4)» 
pmicode char(6)» 
presenLcamer chQr(4)t 
prizm_code char(2)» 
prospecLscore smallint, 
provlder_1 charf4|, 
proWder_2 chari4;, 
proWder_3 char(4), 
retention.score smallint 
smort_min_avail char(l), 
sohojnd char(l), 
state char(2), 
arget_resp_score smallint, 
elcojnd ctiar(4), 
m_company_1 char(3). 
m_datesent_1 date, 
m_datecalL1 date, 
mjead_app_1 ctiar(3\ 
mjead_camp_1 char(3). 
m_sale_app_l ctiar(3), 
m_$ale_camp_1 char(3), 
m_sale_term_1 ct)ar(3), 
m_company_2 char(3), 
m_datesent_2 date, 
m_datecalL2 date, 
mjead_app_2 ctiar(3l, 
mjead.camp_2 chan3), 
m_sale_app_2 char(3V 
m_sale_camp_2 ctiar{3), 
m«salejerm_2 char(3), 
m_company.3 ctiar(3), 
m_datesent_3 date, 
m_datecalL3 date, 
mjead_app_3 cttar(3l 
mjead_camp_3 char(3), 
m_sale_app_3 ctiar(3), 
m_sale_camp_3 char(3). 
m_salejerm_3 ctiar(3), 
m_compony.4 ct)ar(3), 
m_datesent_4 date, 
m_datecalL4 date, 
m_lead_app_4 char(3], 
mjead_camp_4 char(3). 



tm.sale.app_4 char(3), 
tm.sale„camp_4 ct)or(3), 
tm_sale_term.4 ctiar(3), 
tm_compqny_5 char(3), 
tm_datesent_5 date, 
tm_datecalL5 date, 
tmjead^appj char(3), 
tmjead_camp_5 ctiar(3), 
tm_sale_app.5 ct)ar(3), 
tm_sale_camp_5 chor(3), 
tm.sale.term.S char(3), 
totaluse.score smallint, 
traveLscore smallint, 
walmart_avail char(l), 
zip integer, 
2ip«4 smallint, 
-l-BOO.coILsvc ctiar(l), 
_500.svc char(l), 
united_artlstjnd ctiarfl), 
continentaljnd ctiarQ), 
norttiwestjnd ct)ar(1), 
oacc_18c_ctr smallint, 
tot_btns_per_clnt integer, 
tot_wtns_per_Mn integer, 
dom_3_tier_$core smallint, 
kas.domuse.scr smallint, 
kasjntluse^scr smallint, 
kas_totuse_scr smallint, 
kas.lifetime_scr smallint, 
inbound_nosale char(2), 
tech_affLfamily ctiar(l), 
intemet_avail char(1), 
intralata_pic.frz charfl), 
IntematLpic.frz ctiar(l), 
card.usage.score smallint, 
dr_3_tier.$core smallint, 
tftmresp.score smallint, 
ffdrresp_score smallint, 
longdist.use.scr smallint, 
movers.score smallint, 
tm_3_iler_score smallint, 
intrastate_use.scr smollint, 
hlspanic_use_scr smallint, 
territoryjd ctiar(4), 
high_valuejnd ctiar(l), 
lifestage_scr ctiar(1), 
income.scr ctiarfl), 
lifestyle.scr char\1), 
segment Jnd ctiar(1), 
btn_ctr_1 smallint, 
btn_ctr_2 smallint, 
btn_ctr_3 smallint, 
btn_ctr_4 smallint, 
btn_ctr_5 smallint, 
btn_ctr_6 smallint. 
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